Ruby是否有类似pylint的工具?用于分析源代码的错误和简单的编码标准?要是能和cruisecontrolrb整合就好了用于持续集成。或者每个人都编写了如此好的测试以至于他们不需要源代码检查器! 最佳答案 我回顾了这里提供的一堆Ruby工具http://devver.wordpress.com/2008/10/03/ruby-tools-roundup/webmat提到了大多数工具,但如果您想了解更多信息,我会通过示例进行深入介绍。我还强烈推荐使用Metric-Fu,它为您提供了3个更流行的工具的gem/插件安装,并且在构建时考
我为我的应用程序创建了一个自定义记录器,称为CRON_LOG,只需将这段代码添加到config/environment.rbCRON_LOG=Logger.new("#{Rails.root}/log/cron.log")CRON_LOG.level=Logger::INFO然后,当我想记录一些东西时,就这样做:CRON_LOG.info"something"它工作正常,但我想在每条日志消息之前添加当前时间戳。当然,我可以将Time.now添加到我的日志消息中,但我想知道是否有一种方法可以将它作为默认值添加到每条日志消息中。我该怎么做?谢谢。 最佳答案
我正在使用daemonsgem在Ruby中创建一个守护进程。我想将守护进程的输出添加到日志文件中。我想知道将puts从控制台重定向到日志文件的最简单方法是什么。 最佳答案 如果您需要同时捕获STDERR和STDOUT并且不想求助于日志记录:$stdout.reopen("my.log","w")$stdout.sync=true$stderr.reopen($stdout)恢复:$stdout=STDOUT 关于ruby-将"puts"命令输出重定向到日志文件,我们在StackOverf
我有一个不断增长的日志文件。我如何通过Ruby脚本查看和解析它?脚本将解析写入文件的每个新行,并在新行包含字符串'ERROR'时将内容输出到屏幕 最佳答案 defwatch_for(file,pattern)f=File.open(file,"r")f.seek(0,IO::SEEK_END)whiletruedoselect([f])line=f.getsputs"Foundit!#{line}"ifline=~patternendendwatch_for("g.txt",/ERROR/)感谢ezpz的想法,使用select方法你
或者更确切地说,为什么没有更好的工具来分析ruby中的内存,特别是Rails应用程序?最近,我们的Rails应用程序(托管在heroku上)开始在workerdynos中发现大量R14错误。这意味着我们的内存不足。将测功机提高到2倍(512mb->1GB)只能暂时缓解问题,让我相信某处存在内存泄漏。自然地,我的下一步是找到一个可以帮助我发现泄漏源的良好分析工具。也许我只是不知道可用的工具,或者我只是不知道如何使用我拥有的工具。我的愿望是我可以安装一个gem,然后运行关于内存使用统计的报告。由于我的内存问题与运行延迟作业的workerdynos隔离,因此点击端点获取报告并不可行。我看
我们最近开始在我们公司插入合规性,并且需要保留对我们当前在Rails应用程序中管理的数据更改的完整历史记录。我们已经获准将每个操作的描述性内容简单地推送到日志文件,这是一种相当不引人注目的方式。我倾向于在ApplicationController中做这样的事情:around_filter:set_logger_usernamedefset_logger_usernameThread.current["username"]=current_user.login||"guest"yieldThread.current["username"]=nilend然后创建一个看起来像这样的观察者:c
我正在尝试使用“puts”来测试托管在Heroku上的Sinatra应用程序的一些内容。有趣的是,输出似乎排队并且仅在重新启动Herokudyno时显示。我尝试过使用“Thin”和“Webrick”,但遇到了同样的问题。有什么想法吗? 最佳答案 正如您在herokudocs上看到的那样:将此添加到您的config.ru:$stdout.sync=true不要忘记stdout之前的$否则它不会工作。 关于ruby-"puts"输出未显示在Sinatra应用程序的Heroku日志中,我们在S
我正在尝试在Rails中调试模型,因此我使用了以下代码:logger.debug('asasd')但是,我正在跟踪日志文件development.log,但我没有看到它添加到此文件中。我确定这个模块正在运行我已确认运行时错误正在记录到此文件中,并且我在tail时看到了它们。我如何让它工作? 最佳答案 确保您已将日志级别设置为在environments/appropriate_env_file.rb中进行调试:config.log_level=:debug并确保您根据运行环境跟踪正确的日志文件。
我想知道在Rails4中实现GoogleAnalytics跟踪代码和turbo链接的最佳方式是什么。正常的代码段是否有效?我也看过agems为此,但我不确定它的作用。 最佳答案 我喜欢vladCovaliov的解决方案,因为它似乎大多数新帐户都默认使用UniversalAnalytics(我认为这也更好)。但是,我认为这个答案需要与注释掉初始网页浏览量的其他建议相结合,使用page:change事件,并跟踪浏览量,而不是事件。例如,在您的:(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObje
问题我在两台服务器上安装了Rails3.2.15和机架1.4.5。第一个服务器是服务于静态Assets的nginx代理。第二台服务器是为Rails应用程序提供服务的unicorn。在Railsproduction.log中,我总是看到nginxIP地址(10.0.10.150)而不是我的客户端IP地址(10.0.10.62):StartedGET"/"for10.0.10.150at2013-11-2113:51:05+0000我想在日志中有真实的客户端IP。我们的设置HTTPheaderX-Forwarded-For和X-Real-IP在nginx中设置正确,我已经定义了10.0.1